library(dplyr)

## Set working directory 
## to Dataverse replication folder

survey <- read.table("Harris_Data/Harris 1987 Election Survey, study no. 871107/harris_s871107_spss.tab", header = TRUE)

# pid
survey$pid <- c(1:nrow(survey))

# study
survey$study <-"871107"

# study year (year)
survey$year <- 1987

# geographic data (urban)
survey$urban <- NA

# geographic data (region)
survey$region <- NA

# respondent head of household (hh)
survey$hh <- NA

# increasing inequality (inequality)
summary(survey$Q3_2)
survey$inequality <- dplyr::recode(as.character(survey$Q3_2),
                             `1` = "Feel",
                            `2` = "Don't Feel",
                            `3` = "Not Sure")
table(survey$inequality)
table(survey$Q3_2)

# inequality variable (inequality.variable)
survey$inequality.variable <- 1

# union (union.self)
table(survey$F4_1)
survey$union.self <- dplyr::recode(survey$F4_1,
                            `0` = "No",
                            `1` = "Yes")
table(survey$union.self)

survey$union.other <- dplyr::recode(survey$F4_2,
                             `0` = "No",
                             `1` = "Yes")
table(survey$union.other)
table(survey$F4_4) # not sure
survey[survey$F4_4 == 1, c("union.self", "union.other", "F4_3")]

survey$union.self[survey$F4_4 == 1] <- "Not Sure"
survey$union.other[survey$F4_4 == 1] <- "Not Sure"


# employment (employed)
survey$employed <- NA

# empl self
survey$employed.self <- NA

# occupation
table(survey$F1)
survey$occupation <- dplyr::recode(survey$F1,
                            `1` = "Professional",
                            `2` = "Manager, official",
                            `3` = "Proprietor (small business)",
                            `4` = "Clerical worker",
                            `5` = "Sales worker",
                            `6` = "Skilled craftsman, foreman",
                            `7` = "Operative, unskilled laborer (except farm)",
                            `8` = "Service worker",
                            `9` = "Farmer, farm manager, farm laborer",
                           `10` = "Student",
                           `11` = "Housewife",
                           `12` = "Military service",
                           `13` = "Unemployed",
                           `14` = "Retired",
                           `15` = "Welfare",
                           `16` = "Disabled",
                           `17` = "Other (specify)",
                           `18` = "Not sure")
table(survey$occupation)

# occ self
survey$occupation.self <- NA

# household size (hhsize)
survey$hhsize <- NA

# education (educ)
table(survey$F3)
survey$educ <- dplyr::recode(survey$F3,
                      `1` = "Less than high school",
                      `2` = "High school graduate",
                      `3` = "Some college",
                      `4` = "College graduate",
                      `5` = "Post graduate",
                      `6` = "Not sure")
table(survey$educ)

# household income (income)
survey$income <- dplyr::recode(survey$F8,
                        `1` = "7,500 or less",
                        `2` = "7,501 to 15,000",
                        `3` = "15,001 to 25,000",
                        `4` = "25,001 to 35,000",
                        `5` = "35,001 to 50,000",
                        `6` = "50,001 to 75,000",
                        `7` = "75,001 to 100,000",
                        `8` = "100,001 and over",
                        `9` = "Not sure")
table(survey$income)

# age
table(survey$F2)
survey$age <- dplyr::recode(survey$F2,
                     `1` = "18 to 20",
                     `2` = "21 to 24",
                     `3` = "25 to 29",
                     `4` = "30 to 34",
                     `5` = "35 to 39",
                     `6` = "40 to 44",
                     `7` = "45 to 49",
                     `8` = "50 to 64",
                     `9` = "65 to 74",
                    `10` = "75 and over",
                    `11` = "Not sure") # in codebook as x, but values of F2 variable suggest otherwise

table(survey$age)

# race
survey$race1 <- dplyr::recode(survey$F10,
                      `1` = "White",
                      `2` = "Black",
                      `3` = "Asian or Pacific Islander",
                      `4` = "American Indian or Alaskan native",
                      `5` = "Not sure")
survey$race2 <- dplyr::recode(survey$F9,
                              `3` = "Decline/not sure",
                              `1` = "Yes, hispanic",
                              `2` = "No, not hispanic")
table(survey$race1)
table(survey$race2)
sum(is.na(survey$race2))
survey$race1[is.na(survey$race2)]

survey$race <- ifelse(survey$race1 == "Not sure" |
                        is.na(survey$race1), 
                      "Decline/not sure", ifelse(survey$race1 == "White",
                                                 ifelse(survey$race2 == "Decline/not sure" |
                                                          is.na(survey$race2),
                                                        "Decline/not sure",
                                                        ifelse(survey$race2 == "No, not hispanic",
                                                               "Non-Hispanic White",
                                                               "Hispanic White")), "Non-white"))
table(survey$race)
table(survey$race[survey$race1 == "White"])
survey$race[is.na(survey$race2)]

# politics (party)
survey$party <- dplyr::recode(survey$Q8B,
                       `1` = "Republican",
                       `2` = "Democrat",
                       `3` = "Independent",
                       `4` = "Other (vol.)",
                       `5` = "Not sure")
table(survey$party)

# politics (ideology)
survey$ideology <- dplyr::recode(survey$F6,
                          `1` = "Conservative",
                          `2` = "Moderate",
                          `3` = "Liberal",
                          `4` = "Not sure")
table(survey$ideology)

# gender, "original data"
summary(survey$S1)
survey$gender <- (dplyr::recode(survey$S1,
                                      `1` = "Male",
                                      `2` = "Female"))
table(survey$gender)

# religion
survey$religion <- dplyr::recode(survey$F5A,
                          `1` = "Protestant",
                          `2` = "Catholic",
                          `3` = "Jewish",
                          `4` = "Other (specify)",
                          `5` = "None (vol.)",
                          `6` = "Not sure")
table(survey$religion)

# factuals
table(survey$Q9E)
survey$factual1 <- dplyr::recode(survey$Q9E,
                          `1` = "Saw or heard debate",
                          `2` = "Didn't see or hear",
                          `3` = "Not sure")
table(survey$factual1)
survey$factual2 <- NA
survey$factual3 <- NA

## alienation index
survey$dontcare <- dplyr::recode(survey$Q3_1,
                                 `1` = "Feel",
                                 `2` = "Don t feel",
                                 `3` = "Not sure")
survey$dontcount <- dplyr::recode(survey$Q3_3,
                                  `1` = "Feel",
                                  `2` = "Don t feel",
                                  `3` = "Not sure")
survey$leftout <- dplyr::recode(survey$Q3_4,
                                `1` = "Feel",
                                `2` = "Don t feel",
                                `3` = "Not sure")

survey$question_place <- "before party"


# subset
survey_871107 <- survey[,c("pid", "study", "year", "urban", "region", "hh",
                           "inequality", "inequality.variable", "union.self", "union.other",
                           "employed", "employed.self", "occupation", "occupation.self", "hhsize", "educ", "income", 
                           "age", "race", "party", "ideology", "gender", "religion",
                           "factual1", "factual2", "factual3", "dontcare", "dontcount", "leftout",
                           "question_place")]



# save file
#saveRDS(survey_871107, file = "Harris_Data/survey_871107.rds")
